<?php

defined('BASEPATH') OR exit('No direct script access allowed');

class Menu extends CI_Model
{

    /**
     * 添加菜单
     * @param $data
     */
    public function add($data)
    {
        return $this->db->insert('menu', $data);
    }

    /**
     * 修改菜单
     * @param $id
     * @param $name
     * @param $index
     * @param $sort
     * @param $icon
     * @return bool|CI_DB_result
     * @throws MyException
     */
    public function mod($data)
    {
        $update = array_filter($data, function ($var) {
            return $var !== null;
        });
        if (empty($update)) {
            throw new MyException('请至少修改一项', MyException::INPUT_ERR);
        }

        return $this->db->where('id', $data['id'])->update('menu', $update);
    }

    /**
     * 删除菜单
     * @param $menuId
     * @return bool
     */
    public function delete($menuId)
    {
        // 开启事务
        $this->db->trans_begin();

        // 删除菜单
        $this->db->delete('menu', ['id' => $menuId]);

        // 事务提交
        if ($this->db->trans_status() === false) {
            $this->db->trans_rollback();
            return false;
        } else {
            $this->db->trans_commit();
            return true;
        }
    }
}
